package cn.iocoder.yudao.module.trade.api.order.dto;

import cn.iocoder.yudao.framework.common.enums.TerminalEnum;
import cn.iocoder.yudao.module.trade.enums.order.TradeOrderCancelTypeEnum;
import cn.iocoder.yudao.module.trade.enums.order.TradeOrderShareStatusEnum;
import cn.iocoder.yudao.module.trade.enums.order.TradeOrderStatusEnum;
import cn.iocoder.yudao.module.trade.enums.order.TradeOrderTypeEnum;
import java.math.BigDecimal;
import java.time.LocalDateTime;
import java.util.List;
import lombok.Data;

/**
 * 订单信息 Response DTO
 *
 * @author HUIHUI
 */
@Data
public class TradeOrderRespDTO {

    // ========== 订单基本信息 ==========
    /**
     * 订单编号，主键自增
     */
    private Long id;
    /**
     * 订单流水号
     *
     * 例如说，1146347329394184195
     */
    private String no;
    /**
     * 订单类型
     *
     * 枚举 {@link TradeOrderTypeEnum}
     */
    private Integer type;
    /**
     * 订单来源
     *
     * 枚举 {@link TerminalEnum}
     */
    private Integer terminal;
    /**
     * 用户编号
     */
    private Long userId;
    /**
     * 用户 IP
     */
    private String userIp;
    /**
     * 用户备注
     */
    private String userRemark;
    /**
     * 订单状态
     *
     * 枚举 {@link TradeOrderStatusEnum}
     */
    private Integer status;
    /**
     * 购买的商品数量
     */
    private Integer productCount;
    /**
     * 订单完成时间
     */
    private LocalDateTime finishTime;
    /**
     * 订单取消时间
     */
    private LocalDateTime cancelTime;
    /**
     * 取消类型
     *
     * 枚举 {@link TradeOrderCancelTypeEnum}
     */
    private Integer cancelType;
    /**
     * 商家备注
     */
    private String remark;
    /**
     * 是否评价
     */
    private Boolean commentStatus;

    // ========== 价格 + 支付基本信息 ==========
    /**
     * 支付订单编号
     */
    private Long payOrderId;
    /**
     * 是否已支付
     */
    private Boolean payStatus;

    // ========== 发货状态信息 ==========
    /**
     * 发货状态[0/待发货 1/已发货 2/发货失败]
     */
    private Integer deliveryStatus;

    /**
     * 发货失败原因
     */
    private String deliveryReason;

    // ========== 币种相关字段 ==========
    /**
     * 订单币种
     */
    private String orderCurrency;
    /**
     * 汇率
     */
    private BigDecimal exchangeRate;
    /**
     * 调用支付时价格（总），单位：分
     */
    private Integer paymentPrice;
    /**
     * 调用支付时的币种
     */
    private String paymentCurrency;
    /**
     * 下单地区编码
     */
    private String orderAreaCode;
    /**
     * 下单地区名称
     */
    private String orderAreaName;
    /**
     * 审核状态[0/待审核 1/审核通过 2/审核不通过 3/已取消]
     */
    private Integer auditStatus;
    /**
     * 审核原因
     */
    private String auditReason;

    // ========== 活动基本信息 ==========
    /**
     * 拼团活动编号
     *
     * 关联 CombinationActivityDO 的 id 字段
     */
    private Long combinationActivityId;
    /**
     * 拼团团长编号
     *
     * 关联 CombinationRecordDO 的 headId 字段
     */
    private Long combinationHeadId;
    /**
     * 拼团记录编号
     *
     * 关联 CombinationRecordDO 的 id 字段
     */
    private Long combinationRecordId;
    /**
     * 分享状态[0/无需分享 1/未分享 2/已分享]
     * {@link TradeOrderShareStatusEnum}
     */
    private Integer shareStatus;

    /**
     * 激活状态
     */
    private Integer activeState;

    private List<TradeOrderItemRespDTO> items;

    /**
     * 发卡渠道订单id
     */
    private String cdkChannelOrderId;

    /**
     * 发卡渠道内部订单id
     */
    private String cdkChannelInnerOrderId;


}
